home *** CD-ROM | disk | FTP | other *** search
/ Linux Cubed Series 7: Sunsite / Linux Cubed Series 7 - Sunsite Vol 1.iso / system / network / daemons / nfs / nfs-serv.2be / nfs-serv / nfs-server-2.2beta16 / strstr.c < prev    next >
Encoding:
C/C++ Source or Header  |  1993-10-08  |  1.4 KB  |  54 lines

  1. /* strstr.c -- return the offset of one string within another
  2.    Copyright (C) 1989, 1990 Free Software Foundation, Inc.
  3.  
  4.    This program is free software; you can redistribute it and/or modify
  5.    it under the terms of the GNU General Public License as published by
  6.    the Free Software Foundation; either version 2, or (at your option)
  7.    any later version.
  8.  
  9.    This program is distributed in the hope that it will be useful,
  10.    but WITHOUT ANY WARRANTY; without even the implied warranty of
  11.    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  12.    GNU General Public License for more details.
  13.  
  14.    You should have received a copy of the GNU General Public License
  15.    along with this program; if not, write to the Free Software
  16.    Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.  */
  17.  
  18. /* Author:
  19.     Mike Rendell            Department of Computer Science
  20.     michael@garfield.mun.edu    Memorial University of Newfoundland
  21.     ..!uunet!garfield!michael    St. John's, Nfld., Canada
  22.     (709) 737-4550            A1C 5S7
  23. */
  24.  
  25. #ifdef HAVE_CONFIG_H
  26. #include <config.h>
  27. #endif
  28.  
  29. /* Return the starting address of string S2 in S1;
  30.    return 0 if it is not found. */
  31.  
  32. char *
  33. strstr (s1, s2)
  34.      char *s1;
  35.      char *s2;
  36. {
  37.   int i;
  38.   char *p1;
  39.   char *p2;
  40.   char *s = s1;
  41.  
  42.   for (p2 = s2, i = 0; *s; p2 = s2, i++, s++)
  43.     {
  44.       for (p1 = s; *p1 && *p2 && *p1 == *p2; p1++, p2++)
  45.     ;
  46.       if (!*p2)
  47.     break;
  48.     }
  49.   if (!*p2)
  50.     return s1 + i;
  51.  
  52.   return 0;
  53. }
  54.